## **Lab 1 Grading Rubric**

Lab 1 is graded in 2 main portions - Lab Report and Lab Demo. The lab report is worth 40% of the grade, and the Lab Demo is worth 60% of the grade. To receive full credit, you must demo the lab with a perfect correctness score, meeting all the requirements of the lab. If the lab is not finished correctly, and some parts are not working, your lab demo score will be the number of points added up out of 100 multiplied by 45.

In order to get full credit for the report, please include all code (that you implemented for the lab). Missing code will be (-5) points. Just a reminder that the report is done individually. Please do not copy answers or work together when writing the report.

## Lab 1 Report Grading:

|                                                     | Full Credit                                                                                                                                                                                           | Partial Credit                                                                                           | No Credit |
|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-----------|
| Introduction and Requirement                        | 10 points  - Background summary of UART protocol. Introduction of the lab and tb design requirements.                                                                                                 | - Partial credit (1/2)<br>may be awarded for<br>minor mistakes in<br>explanations/<br>schematic designs. | 0 points  |
| Nicer UART                                          | 5 points - Explanation of the code implemented in the model_uart module.                                                                                                                              | пп                                                                                                       | пп        |
| "An easier way to load<br>the sequencer<br>program" | <ul> <li>Explanation and identification of the original code/tasks in the tb. (2)</li> <li>Description of the code implemented in tb.v. (3)</li> </ul>                                                | n 1                                                                                                      | II II     |
| "Clock Dividers"                                    | <ul> <li>5 points</li> <li>Waveform and clock frequency of clk_en (1)</li> <li>clk_en duty cycle (1)</li> <li>Value of clk_div (1)</li> <li>Schematic of clk_div, clk_en, and clk_en_d (2)</li> </ul> | пп                                                                                                       | пп        |

|                 | Full Credit                                                                                                                                                                                               | Partial Credit | No Credit |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-----------|
| "Debouncing"    | 5 points  - Explanation of clk_en_d and clk_en functionality (1)  - Explanation of clk_dv_inc (1)  - Waveforms of clk_en, step_d[1:0], btnS, clk_en_d, and inst_vld (1)  - Schematic of above signals (2) | пи             | пп        |
| "Register File" | 5 points  - Sequential or Combinatorial Logic 1 (1)  - Sequential or Combinatorial Logic 2 (1)  - Readout logic (1)  - Register file circuit diagram (2)  - Waveform of R3 (1)                            | пп             | 11 11     |
| Conclusion      | 5 points  - Summary of the design, problems encountered, solutions to them, and suggestions for improvement.                                                                                              | N/A            | пп        |
| TOTAL           | 40 points                                                                                                                                                                                                 |                |           |

## Lab 1 Demo Grading:

|                                 | Full Credit                                                                                           | Partial Credit   | No Credit                  |
|---------------------------------|-------------------------------------------------------------------------------------------------------|------------------|----------------------------|
| Sequencer Operation Demo Points | 15 points                                                                                             | 5 points         | 0 points                   |
|                                 | - Translation of the commands into binary - Output of the correct register values on the UART console | - 1 Session late | - More than 1 session late |

|                                                          | Full Credit                                                                                                                                         | Partial Credit                                                                                                                                           | No Credit                         |
|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| Nicer UART                                               | - Outputs one line after carriage return is received - Keeps track of/ stores the bits in a register until carriage return                          | <ul> <li>Not printing the full</li> <li>4 bits every time,</li> <li>but able to print 3</li> <li>bits or some</li> <li>variations of the bits</li> </ul> | Unable to change the bits printed |
| File I/O (An Easier Way<br>to Load Sequencer<br>Program) | - Takes correct format of the instructions - Correctly modifies test bench such that it loads seq.code into an array and executes every instruction | 5 points  - Able to load seq.code into the testbench                                                                                                     | 0 points                          |
| Fibonacci Numbers                                        | - Correct sequence of instructions for 10 fibonacci numbers printed on UART                                                                         | n/a                                                                                                                                                      | 0 points                          |
| Clock Enable                                             | - clk_en added to simulation's waveform - Waeform with two occurences of clk_en                                                                     | 12 points - Not the exact period                                                                                                                         | 0 points - No clock enabled       |
| TOTAL                                                    | 60 POINTS                                                                                                                                           |                                                                                                                                                          |                                   |